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© A standard logic block, or macrocell, is provided 
for use on programmable logic devices. The macro- 
cell uses RAM to perform logic functions, and further 
includes circuitry which allows writing of data to the 
RAM during use. Each logic block can be configured 
at programming time to be either a user RAM, 



allowing the user to write data to such memory 
during use, or configured as performing logic func- 
tions. The contents of macrocells configured as pro- 
viding logic functions cannot be changed except by 
reprogramming the device. 
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LOGIC BLOCK FOR PROGRAMMABLE LOGIC DEVICES 



The present application contains subject matter 
in common with copending European Patent Ap- 
plication No (Page White & Farrer reference 
66563/RP) entitled CONFIGURATION MEMORY 
FOR PROGRAMMABLE LOGIC DEVICES, filed on 5 
even date herewith. 

The present invention relates generally to in- 
tegrated circuit devices, and more specifically to 
programmable logic devices which are configurable 
by a user. 10 

Programmable logic devices are becoming in- 
creasingly popular in the electronics industry be- 
cause of their flexibility. These devices allow a user 
to configure a standard part to perform a wide 
variety of standard logic functions. Since a single 75 
standard device can be configured many different 
functions, the total cost of using such a device in a 
system can be significantly less than the cost of 
custom designed parts; especially in cases where 
product volume is not extremely large. 20 

Many programmable logic devices can be pro- 
grammed only once. This may be done as a final 
metallization mask step at a silicon foundry. An- 
other design is to provide a device which is prog- 
rammable by the use of fusible links, with the 25 
programming being performed by the user using 
specialized programming equipment. 

Other programmable logic device designs allow 
the devices to be reprogrammed by the user. 
These designs typically incorporate non-volatile 30 
memory such as EPROMs or EEPROMS to retain 
the programming, or configuration, information. If it 
is desired to reprogram the device, the configura- 
tion information stored in non-volatile memory on 
.the device can be changed, which changes the 35 
functions performed by that device. 

Reprogrammable logic devices can also be 
constructed using RAM, usually SRAM, to retain 
configuration information. Although such devices 
retain their configuration only so long as power is 40 
applied to the device, they are easily reprogram- 
med by the user. The use of RAM to perform logic 
functions has long been known. One approach to 
using RAM in a programmable logic device is to 
provide an array of identical logic blocks, also 45 
referred to as macrocells, which are interconnected 
by matrices of programmable switching elements. 

Referring to Figure 1, such a programmable 
logic device is referred to generally as 10. The 
device 10 contains an array of macrocells 12-15. so 
Only 4 such macrocells are shown in Figure 1, but 
a typical actual device would contain a much larger 
array. 

The macrocells 12-1 5 are interconnected 
through programmable switching matrices 16-22. 



The programmable switching matrices 16-22 each 
contain a plurality of programmable switches for 
connecting pairs of signal lines passing thereth- 
rough. Their function is similar to the well known 
cross bar switch. By properly programming the 
switching matrices, signals can be routed between 
non-physically adjacent portions of the device 10. 
For example, an output signal from macrocell 14 
can be used as an input to macrocell 13 by routing 
such signal through programmable switching ma- 
trices 21, 22, 20, and 17 in that order. 

Inputs are supplied to the device through input 
buffers 24 connected to input pins 26. The signals 
from input buffers 24, preferably available in true 
and complemented versions, are connected to 
switching matrix 16. From this point, they can be 
routed to different parts of the device 10 as need- 
ed. Output buffers 28 are driven by signals routed 
through switching matrix 21, and drive output pins 
30. 

In many devices, the input/output pins are pro- 
grammable as to their function. Thus, any given 
input/output pin can be programmed to be an input 
buffer 24 or an output buffer 28. Such technique is 
preferably used with the present invention, with 
input buffers 24 being those input/output buffers 
which have been programmed to be inputs, and 
output buffers 28 being those which have been 
programmed to be outputs. 

The number of signal lines which connect var- 
ious portions of the device 10 can be varied as 
desired. As shown in Figure 1, each macrocell 12- 
15 has n inputs and m outputs. All macrocells are 
preferably identical for ease of design and layout. 
All programmable switching matrices 16-22 are 
also preferably identical, with the possible excep- 
tion of matrices 16 and 21 used to communicate 
with the input buffers 24 and output buffers 28 
respectively, k signal lines are routed between 
each programmable switching matrix. A typical, 
actual device 10 design might include, for example, 
a ten by ten array of macrocells, with program- 
mable switching matrices between macrocells as 
indicated in Figure 1. Each macrocell could have n 
= 24 inputs and m = 4 outputs, with k = 32 
signal .lines between each programmable switching 
matrix. 

In a device such as described in connection 
with Figure 1, it would be desirable to have user 
RAM on the device. Unlike the RAM used to store 
configuration information, and thus defining logic 
functions, the user RAM would be available for use 
as a memory by the user. 

It is therefore an object of the present invention 
to provide a programmable logic device having 
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RAM available to the user in addition to logic 
functions. 

It is another object of the present invention to 
provide such a device wherein logic blocks used 
for the user RAM and programmed logic have the 
same design and layout. 

It is a further object of the present invention to 
provide such a device wherein the user can selec- 
tively configure each logic block to function as 
user-writable RAM or programmed logic. 

Therefore, according to the present invention, a 
standard logic block, or macrocell, is provided for 
use on programmable logic devices. The macrocell 
uses RAM to perform logic functions, and further 
includes circuitry which allows writing of data to the 
RAM during use. Each logic block can be config- 
ured at programming time to be either a user RAM, 
allowing the user to write data to such memory 
during use, or configured as performing logic func- 
tions. The contents of macrocells configured as 
providing logic functions cannot be changed except 
by reprogramming the device. 

The novel features believed characteristic of 
the invention are set forth in the appended claims. 
The invention itself however, as well as a preferred 
mode of use, and further objects and advantages 
thereof, will best be understood by reference to the 
following detailed description of an illustrative em- 
bodiment when read in conjunction with the accom- 
panying drawings, wherein: 

Figure 1 is a block diagram of a programmable 

logic device as found in the prior art; 

Figure 2 is a block diagram of a portion of a 

macrocell according to the present invention; 

and 

Figure 3 is a block diagram of a preferred 
macrocell according to the present invention. 

Referring to Figure 2, a decoder 40 has n 
inputs 42. 2 n row signal lines 44 are output from 
the decoder 40 and connected to an SRAM 46. 
SRAM 46 is preferably a single column SRAM, 
having 2" positions individually addressed by the 
row lines 44 of the decoder 40. The value of the 
selected SRAM 46 entry is connected to a column 
signal line 48 which provides an input signal to 
sense amplifier 50. The output of sense amp 50 
provides output signal DATA OUT. 

A write driver 52 is also connected to the 
column line 48. Write driver 52 consists of P- 
channel transistors 54 and 56, and N-channel tran- 
sistors 58 and 60. Transistors 56 and 58 are con- 
nected to the column signal line 48, and are driven 
by a signal DATA IN. DATA IN contains a value to 
be written into an SRAM 46 location. 

Signals WE (WRITE ENABLE) and WE-bar are 
used to write data into the SRAM 46. When WE is 
high WE-bar is low, which turns on transistors 54 
and 60. In this event, column line 48 is driven to a 



value determined by DATA IN. If DATA IN is high, 
column line 48 is driven to ground, and if DATA IN 
is low. column line 48 is driven to Vcc. The value 
placed on column line 48 is stored into whichever 

5 SRAM 46 position is currently addressed by the 
signals used to drive decoder 40. 

Figure 3 shows the construction of a preferred 
macrocell 68 utilizing the circuitry described in 
connection with Figure 2. Macrocell 68 contains 

to four decoders 70 and four associated SRAMs 72. 
Decoders 70 each have four input signal lines and 
are each capable of addressing 16 bit positions. 
The corresponding SRAMs 72 therefore each have 
16 bit storage positions. Separate control lines are 

rs provided to address each decoder, so that a total 
of 16 decoder control lines 74 are provided to the 

macrocell 68. 

Each SRAM drives a column signal line 76 
which is connected to a circuit block 78 containing 

20 a sense amplifier and write driver as described in 
connection with Figure 2. Sense amplifier output 
lines 80 are connected to combinational and se- 
quential logic blocks 82, which in turn drive macro- 
cell output lines 84. Logic blocks 82 preferably 

25 contain flip-flops and combinational logic to provide 
various output functions of the values on output 
lines 80. 

Four input data lines 86 are provided to the 
macrocell 68, with one line being connected to the 

30 write driver in each circuit block 78. Control signal 
lines 88 are provided to the macrocell 68. and 
serve a dual purpose depending on how the 
macrocell 68 is configured. Switch 90 is used to 
route the signal lines 88 to write enable lines 92 or 

35 combinational and sequential logic control signal 
lines 94. 

Figure 3 illustrates a view of the macrocell 68 
seen by a user. Not shown are the configuration 
bits and their associated control lines used to ac- 

40 tually configure the macrocell 68. For example, 
configuration bits are contained within the combin- 
ational and sequential logic blocks 82 which drive 
multiplexers to select which of the available logic 
functions are to be performed. These configuration 

45 bits are set at configuration time, and cannot be 
changed during normal use. Switch 90 is defined at 
configuration time in a similar manner. If macrocell 
68 is to be used for providing logic functions, 
control signals on lines 88 are switched to combin- 

50 ational and sequential logic control signal lines 94. 
If the macrocell 68 is configured to function as 
user-writable SRAM, four of the signals 88 are 
switched to write enable signal lines 92. When 
macrocell 68 is functioning as user-writable SRAM, 

55 combinational and sequential logic blocks 82 are 
configured to simply provide a direct connection 
between sense amp output lines 80 and macrocell 
output lines 84. Configuration of the various ele- 
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merits within the macrocell 68 is controlled by the 
settings of configuration bits within the macrocell 
68. As known in the art, these configuration bits are 
written to using a separate set of address and 
control lines from those seen by the user during 
normal operation, and this separate set of signal 
lines is not shown in Figure 3. 

When macrocell 68 is configured to function as 
a logic block, DATA IN signal lines 86 are ignored 
and the write drivers in blocks 78 are disabled. 
Control signal lines 88 are switched to connect to 
signal lines 94, and used to control the state of 
combinational and sequential logic blocks 82. The 
signals on lines 92 are used to, for example, clock 
flip-flops, set or reset flip-flops provide output en- 
able signals for signal lines 84, and to perform 
similar functions. In this configuration, macrocell 68 
operates much as do those used in the prior art. 

When macrocell 68 is configured to function as 
user-writable RAM, switch 90 is configurated to 
route four selected control signals 88 to write en- 
able signal lines 92. Four additional control signals 
88 can be used to provide the output enable sig- 
nals on lines 94. The combinational and sequential 
logic blocks 82 are configured to provide a direct 
connection between signal lines 80 and signal lines 
84. The write drivers within logic blocks 78 are 
enabled, and data input signal lines 86 provide data 
thereto. 

When macrocell 68 is used as user-writable 
RAM, decoder control signal lines 74 are inter- 
preted as address lines. If desired, each of the 
decoders 70 can be provided with identical address 
inputs, which configures the macrocell 68 as a 
16x4 RAM. By proper selection of the control sig- 
nals 74, macrocell 68 can also be configured as a 
32x2 RAM or a 64x1 RAM. To configure the 
macrocell 68 as a 64x1 RAM, the four signal lines 
84 are tied to a common point in a programmable 
switching matrix outside the macrocell 68, with only 
one at a time being enabled by the output enable 
signals available on signal lines 94. Since the 
shape of the RAM is determined by the decoder 
control lines 74, the shape of the RAM is actually 
configured in the programmable switching matrix 
which provides the input signal lines to the macro- 
cell 68. Different macrocells 68 can be configured 
together so as to provide user-writable RAM of any 
desired depth and width. 

As will be appreciated by those skilled in the 
art, the use of macrocells 68 which can be config- 
ured to provide logic functions or to function as 
user-writable RAM allows increased flexibility in 
configuring a programmable logic device. If only 
dedicated RAM is provided as user-writable RAM, 
it is certain that in many cases the proportions of 
available user-writable RAM and RAM providing 
logic functions will not be correct. With a macrocell 



68 which can be configured to provide either func- 
tion, a user can configure the programmable logic 
device in the most efficient manner to allow full use 
of all elements on the chip. This allows one or a 

5 small number of standard parts to be used for a 
wide variety of applications. 

As described in related spending application 
Serial No. , titled CONFIGURATION MEMORY 
FOR PROGRAMMABLE LOGIC DEVICE, a battery 

to backup system can be used to preserve the con- 
tents of all SRAM when power is lost to the prog- 
rammable logic device. Configuration data is re- 
tained during a power loss, so that the device need 
not be reconfigured each time it is powered up. In 

75 addition, since the same macrocells 68 are used 
for user-writable memory and for logic functions, 
the user-writable memory is also saved by the 
backup supply. 

While the invention has been particularly 

20 shown and described with reference to a preferred 
embodiment, it will be understood by those skilled 
in the art that various changes in form and detail 
may be made therein without departing from the 
spirit and scope of the invention. 

25 

Claims 

1. A circuit block for use in programmable logic 
30 devices, comprising: a decoder; 

a random access memory having a plurality of bits 

addressed by said decoder; 

a sense amplifier connected to said random access 

memory; 

35 a write driver connected to said random access 
memory; and 

means for configuring the circuit block to function 
as user-writable memory or to provide a logic func- 
tion. 

40 2. The circuit block of Claim 1, wherein said write 
drivers are disabled when the circuit block is con- 
figured to provide a logic function. 

3. The circuit block of Claim 1, wherein said ran- 
dom access memory provides a plurality of out- 

45 puts, each corresponding to a column of memory, 
and wherein said sense amplifier provides a sepa- 
rate sense amplifier for each memory column. 

4. The circuit block of Claim 3, wherein each col- 
umn of random access memory has a separate 

so decoder for addressing the bits of the column. 

5. The circuit of Claim 4, wherein each column of 
random access memory further has an indepen- 
dently addressable write driver connected thereto. 

6. The circuit block of Claim 1 , further comprises: 
55 combinational and sequential logic coupled be- 
tween said sense amplifier and outputs of the cir- 
cuit block. 

7. The circuit block of Claim 6, wherein said com- 
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8 



binationa! and sequential logic includes flip-flops. 

8. The circuit block of Claim 6, further comprising: 
control signal inputs to the circuit block, wherein 
said control signal inputs perform control and 
switching functions in said combinational and se- 
quential logic when the circuit block is configured 
to provide a logic function, and wherein said control 
signal inputs provide write enable signals to said 
independently addressable write drivers when the 
circuit block is configured to function as user- 
writable memory. 

9. A programmable logic device, comprising: 
a plurality of input and output buffers; 

a plurality of programmable switching matrices; 
and 

a plurality of logic blocks interconnected with said 
programmable switching matrices, wherein each 
logic block is configurable to function as user- 
writable random access memory or to provide a 
logic function. 

10. The device of Claim 9, wherein each of said 
logic blocks comprises: 

at least one decoder; 

a random access memory organized as a plurality 
of memory columns and addressed by said de- 
coder; 

a sense amplifier connected to each column of said 
random access memory; 

a write driver connected to each memory column; 
and 

means for configuring the logic block to function as 
user-writable memory or to provide a logic function. 

11. The device of Claim 10, wherein the write 
drivers within a logic block are disabled when that 
block is configured to provide a logic function. 

12. The device of Claim 10, wherein each memory 
column within a logic block is addressed by a 
separate decoder. 

13. The device of Claim 12, wherein each logic 
block contains 4 decoders and 4 memory columns. 

14. The device of Claim 10, wherein each logic 
block further comprises combinational and sequen- 
tial circuitry between said sense amplifiers and 
outputs of the logic block. 

15. The device of Claim 10, wherein said logic 
blocks and said programmable switching matrices 
are interconnected to form a rectangular array, with 
all inputs of each logic block connected to a prog- 
rammable switching matrix. 

16. The device of Claim 9, further comprising: 
a backup battery; and 

means for detecting a loss of power to the device, 
wherein said backup battery is connected so as to 
provide power to said logic blocks and to said 
programmable switching matrices, but not to said 
input and output buffers, whenever a loss of power 
is detected. 

17. A method for defining the function of a prog- 



rammable logic device, comprising the steps of: 
providing a device having an array of logic blocks 
interconnected by programmable switching matri- 
ces; and 

s configuring each logic block independently to func- 
tion as user-writable random access memory or to 
perform a logic function. 
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